--[[ 编码: WMS-19-03 名称: 容器货品明细-码盘-条码输入后 作者:HAN 日期:2025-1-29 级别:固定 (说明本段代码在项目中不太会变化) 函数: AfterQRCodeInput 功能: -- 在码盘界面,输入条码/扫码后,需要通过条码获取 货品的信息 -- 注: 本代码根据 新兴项目 作为原型开发,供其它项目参考 -- 新兴项目是从上架单明细中获取是否有该条码的货品,扫描的二维码是 批次+卷号 是一个唯一号 在【上架单明细】中是 S_SERIAL_NO 产品序列号 更改记录: --]] wms_base = require( "wms_base" ) function AfterQRCodeInput ( strLuaDEID ) local nRet, strRetInfo local attrs -- step1 获取5600码盘界面中表头界面的输入的条码 nRet, attrs = m3.GetSysInputParameter( strLuaDEID ) if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), "获取当前输入面板里的属性失败! "..attrs ) end local input_attr = m3.KeyValueAttrsToObjAttr(attrs) local qr_code = input_attr.QRCode if (qr_code == nil or qr_code == '') then return end -- step2 查询【上架单明细】 -- 注: 下面的查询条件可能不同项目会有所不同 -- N_B_STATE = 0 说明这条【上架单明细】还有量可以进行绑定 local strCondition = "S_SERIAL_NO = '"..qr_code.."' AND N_B_STATE = 0" local putaway_detail nRet, putaway_detail = m3.GetDataObjByCondition(strLuaDEID, "Putaway_Detail", strCondition ) if ( nRet == 1) then -- 前端显示信息 mobox.setInfo( strLuaDEID, "【上架单明细】中不存在满足目前条码条件的记录!" ) return end if (nRet ~= 0) then lua.Error( strLuaDEID, debug.getinfo(1), "获取【上架单明细】信息失败! " .. strRetInfo) end -- 计算出可以绑定的数量 local total_qty = putaway_detail.qty local alloc_qty = putaway_detail.alloc_qty local acc_c_qty = putaway_detail.acc_c_qty local acc_b_qty = putaway_detail.acc_b_qty -- 可以绑定的数量 = 总数量 - 分配量 - 取消数量 - 已经绑定数量 local qty = total_qty - alloc_qty - acc_c_qty - acc_b_qty if ( qty <= 0 ) then -- 前端显示信息 mobox.setInfo( strLuaDEID, "绑定数量已满!" ) return end -- 组织 容器货品明细 数据对象属性 -- 这个加入到“正在码盘” -- 注: 下面的查询条件可能不同项目会有所不同 -- 设置信息 local attr_array = {} local insert_row = {} attr_array[1] = lua.KeyValueObj( "S_PUTAWAY_NO", putaway_detail.putaway_no ) attr_array[2] = lua.KeyValueObj( "S_ITEM_CODE", putaway_detail.item_code ) attr_array[3] = lua.KeyValueObj( "S_ITEM_NAME", putaway_detail.item_name ) attr_array[4] = lua.KeyValueObj( "S_SERIAL_NO", putaway_detail.serial_no ) attr_array[5] = lua.KeyValueObj( "S_BS_NO", putaway_detail.bs_no ) attr_array[6] = lua.KeyValueObj( "F_NET_WEIGHT", putaway_detail.net_weight ) attr_array[7] = lua.KeyValueObj( "F_GROSS_WEIGHT", putaway_detail.gross_weight ) attr_array[8] = lua.KeyValueObj( "S_WU", putaway_detail.weight_unit ) attr_array[9] = lua.KeyValueObj( "S_UOM", putaway_detail.uom ) attr_array[10] = lua.KeyValueObj( "F_QTY", qty ) insert_row.attrs = attr_array local value = {} -- insert_subtable_page_row action 的value 格式 value.page_name = "正在码盘" value.row[1] = insert_row local action = {} action.action_type = "insert_subtable_page_row" action.value = value -- 设置action nRet, strRetInfo = mobox.setAction( strLuaDEID, '['..lua.table2str(action)..']' ) if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), "setAction失败! "..strRetInfo..' action = '..lua.table2str(action) ) end end